# SHARED PERIPHERAL ARCHITECTURE

# CROSS REFERENCE TO RELATED APPLICATIONS

[0001] This application is a continuation of U.S. Application No. 09/660,577, filed September 13, 2000, which is incorporated by reference herein in its entirety.

#### BACKGROUND OF THE INVENTION

# Field of the Invention.

[0002] The present invention relates, in general, to disk multiprocessing circuits, and, more particularly, to software, systems and methods enabling multiple processors to flexibly share a group of peripheral circuits. Even more particularly, the present invention relates to a multiple processor disk drive controller having a shared peripheral architecture.

### Relevant Background.

Multiprocessor architectures have been widely [0003] used for general purpose computing systems where it is instruction throughput. higher provide desired to However, multiprocessors have had limited application in less computing that are embedded computing systems intensive. One issue in embedded systems is the efficient sharing of peripherals between the multiple processors in a non-conflicting manner.

[0004] Disk drive controller devices are an example of embedded systems that conventionally use a single processor core accessing multiple peripheral circuits.

Disk drive controller circuits are circuits that manage data storage and retrieval on associated storage hardware. The disk controller provides a host interface to one or more host computers and conducts data transactions with the host(s) using an available protocol over this host interface. At a basic level, the controller circuit receives read and write requests over the host interface and then performs the requested operation.

[0005] A read request typically identifies a location in the storage device from which data is to be read. A response to a read request includes the data stored at the specified location. A write request includes data that is to be written and specifies a location where it is to be stored. In response to a write request, the controller causes the data to be stored at the specified location and typically sends an acknowledgment signal to the device that generated the write request.

[0006] In addition to these basic transactions, a disk controller may support other functionality and interfaces. For example, a controller may include a serial port, a general purpose input output (GPIO) port, RS-232 serial ports, and the like. With respect to functionality, the disk drive controller may implement timers, interrupt controllers, diagnostic circuitry, and the like.

drive controllers are disk Preferably, [0007] integrated circuits having single implemented as The processor core controls one embedded processor core. or more peripheral circuits that implemented particular The processor core is coupled disk drive functionality. to the peripherals by a shared peripheral bus. In systems with but a single processor core, there was never a problem with peripheral access as the single processor had complete control over the bus and each peripheral.

[0008] The processor executes previously stored program code to implement responses to commands received from host computers. A portion of the code that controls servo functionality (called "servo code") must operate at a high priority to ensure that the servo mechanism(s) that position the read/write head correctly with respect to the media are performed efficiently and accurately during read and write operations. Other code is also provided to handle lower priority functions such as cache management, defect table management, peripheral interaction, and the like.

[0009] There is continuing need to improve the servo control mechanisms. As a result, the servo code is becoming more complex and demands an increasing load on the limited processor resources. At the same time, improvements in disk controller functionality and features result in increasing processor demands being placed by the lower priority code and peripheral circuits. Single processor designs use available interrupt mechanisms to give higher priority to servo code execution when lower priority code competes for processor resources. However, this impacts the ability to execute lower priority code efficiently.

These trends indicate a need for disk drive [0010] controllers with greater processing power. In particular, a need exists for disk controllers that implement parallel processing with multiple processing units to handle disk peripheral control, and servo access requests, Multiprocessor designs functionality more efficiently. ability to prioritize code servo provide improved

execution while maintaining available processor resource for execution of other code.

[0011] To provide improved storage functionality and efficiency, dual processor disk drive controllers are being developed. Dual processors enable the controller to handle multiple tasks in parallel. However, to save chip area it is desirable to implement at least some, if not all, peripheral circuitry as shared between the multiple processor cores. However, this creates contention between the multiple processors whenever both wish to access the same shared peripheral at the same time. Hence, a need exists for software, systems and devices for implementing efficient sharing of peripherals in multi-processor disk controller devices.

### SUMMARY OF THE INVENTION

[0012] Briefly stated, the present invention involves a disk drive controller including a plurality of processors and a plurality of shared peripheral units. A shared bus couples the peripheral units and the processors. A bidirectional multiplexor selectably couples each of the plurality of processors to the shared bus in response to an owner signal. A set of peripheral-share registers are provided where a first member of the set includes an entry associated with each of the plurality of peripheral units and holds a state value indicating which of the plurality of processors currently owns the associated peripheral unit.

# BRIEF DESCRIPTION OF THE DRAWINGS

- [0013] Fig. 1 shows a disk drive controller in accordance with the present invention;
- [0014] Fig. 2 shows data flow diagram illustrating functionality of a disk drive controller in accordance with the present invention;
- [0015] Fig. 3 illustrates in block diagram form;
- [0016] Fig. 4 shows a timing diagram of events illustrating operation of an embodiment of the present invention; and
- [0017] Fig. 5 shows a register layout of peripheral share registers used in an implementation of the present invention.

#### DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

illustrated is The present invention [0018] described in terms of a hard disk controller but it will be appreciated that the essential teachings are readily applied to many applications using multiple embedded share one or more peripherals. that processors particular, many processor-controlled devices must execute operating system code as well as "application code" that perform application specific functions. Such devices will processor core dedicated benefit from having а independent executing operating system code while an Further, devices may processor executes application code. benefit from having multiple processors executing separate the application code. within processes threads or Accordingly, the specific implementations within a disk drive controller are not construed as limitations on the teachings of the present invention. Although two processors are used in the particular embodiment, any number of processors may be used. Moreover, the present invention is readily extended to any number and variety of peripheral units.

Fig. 1 illustrates in simplified form a drive [0019] system 100 in which the present invention is embodied. Disk drive system 100 processes requests and commands from a host computer 101 that direct drive system to perform specific behavior involving disk drive assembly Examples include reading and writing data providing state information such as defect tables, error status, and the like. Disk control unit 103 includes data to generate processing capacity as well as memory requests. received commands and responses to generated responses return data, state information, and/or error codes depending on the particular operation being performed.

[0020] Disk drive assembly 107 implements physical mass storage typically on a plurality of magnetic disks and read/write head electronics for transferring data with the disks. Disk drive assembly includes the read channel hardware for preprocessing and amplifying data read from the magnetic media as well as motors for spinning the disks and positioning the read/write head electronics with respect to the disk surfaces.

[0021] Host 101 typically comprises a data processing device such as a personal computer, server, workstation or the like that requires access to bulk data storage capabilities of disk drive assembly 107. Host 101 sends write commands and data via controller 103 to write data

onto the disks as well as read commands to retrieve previously written data from disks within disk drive assembly 107. On both read and write operations the data transmitted from the host to the disk controller includes an indication of a specific location or set of locations on the disk drive assembly that contains the data that is to be accessed.

through exchanged is data that [0022] The controller 103 is typically buffered in buffer memory 104 memory controller accessible via is subsequently transmitted to disk assembly 107 or host 101. Buffer memory 104 is used to overcome differences between the speed at which host 101 operates as compared to the speed at which disk assembly 107 operates. In place of or in addition to buffer memory 104, a cache memory may be implemented by appropriate changes (e.g., tag management, hit/miss detection, and the like) to memory controller 109.

In accordance with the present invention, disk [0023] controller 103 comprises multiple processor cores 110 and 111 labeled P0 and P1 in Fig. 1. Processor cores 110 and comprise embedded digital signal processor (DSP) devices in a particular embodiment, however, the present invention is usefully implemented using a variety of processor technologies including reduced instruction set computers instruction set (RISC), complex computers (CISC), and the like. Although processors 110 and 111 are they identical, substantially typically for particular differentiated to optimize performance tasks.

[0024] Disk controller 103 includes a variety of peripherals coupled to processors 110 and 111 through a

processor bus 102. With reference to Figure 2 as well as Figure 1, processor bus 102 includes an address bus and a data bus for each processor 201. The address/data bus lines from each processor 201 are coupled to a multiplexor 205. Multiplexor 205 couples a selected processor bus 102 to a selected peripheral via a multiplexed processor bus 114 coupled to each peripheral.

Peripherals include read channel unit 105 that [0025] interfaces with disk drive assembly 107 to process data coming from the read channel electronics. Servo control unit 108 generates control signals and monitors feedback read/write spin speed and to related Input/output (I/O) 106 provides one or more positioning. serial ports, parallel ports, and the like for accessing operation, testing, during disk controller 103 Read only memory (ROM) 112 stores program maintenance. code and optimization parameters executed by processors ROM 112 may be re-writable under control of 110 and 111. one or the other of processors 110 and 111 so as to fine Interrupt controller 113 tune or change functionality. handles interrupt events such as when errors are detected generated by any of the peripheral components, conflicts between devices, and prioritization of running code.

[0026] Because the peripherals are shared by both processors 110 and 111, it is necessary to provide a means of arbitrating access to each peripheral so that each peripheral is certain at any point in time which processor it is in communication with. Fig. 2 illustrates in block diagram form principal components of the peripheral access mechanisms within disk controller 103 in accordance with the present invention. Bus 102 and multiplexed bus 114

are illustrated as unified, however it should be understood that they comprise both address portions as well as data portions and may include separate control portions as well.

[0027] In the exemplary implementation, each bus 102 comprises a complete set of address and data lines for each processor 201. Multiplexor(s) 205 operate under control of an OWNER signal provided to each multiplexor 205 by protocol logic 204 to select which of the address and data lines are coupled to the associated peripheral 202. Preferably, each processor bus 102 is multiplexed as close to the processors as possible and the multiplexed output 114 (e.g., a single address/data bus) is routed to each of the peripherals.

[0028] Multiplexors 205 enable any processor 201 to access any peripheral while ensuring that each peripheral is only used by a single processor at any given time. Peripherals 202 may be shared statically by assigning ownership to a particular processor 201 at boot time. Alternatively, peripherals 202 may be shared dynamically such that either processor 201 may request access to any peripheral 202 at any time.

of controlled set by are Peripherals [0029] peripheral control registers 203 that reside at The peripheral control registers hold peripheral unit. relates to that data peripheral-specific functionality, addressing, and/or data transferred to the Dynamic sharing of peripherals peripheral. accomplished by sharing the peripheral control registers 203 that reside at each peripheral unit. The sharing of is important because peripheral control registers 203 duplication of these registers would result in a need for

duplicate sets of control registers at each peripheral unit 202 and the content of the registers 203 would have to be multiplexed based on peripheral ownership in order to control a peripheral unit 202.

Fig. 3 shows a data flow of a two processor [0030] implementation in accordance with the present invention. 301 is associated 1/0 register Peripheral particular peripheral 202 and holds data entering and Hence, a peripheral leaving an associated peripheral. control register 301 is associated with each peripheral 202 that can be shared in accordance with the present Peripherals 202 are memory mapped devices which means that of the finite address space reachable by the address lines 310, each peripheral 202 is assigned a unique range of addresses for I/O purposes. particular example address busses 310 are ten bits wide defining a total address space comprising 1024 addresses. This range is apportioned amongst the peripherals 202 not only to identify the particular peripherals, but also to identify registers or other memory mapped devices within a particular peripheral.

[0031] Decode logic 304 decodes the address applied by DSP\_0 while decode logic 306 decodes the address applied by DSP\_1. Decode logic 304 and 306 receive control signals such as a read/write control signal that indicate whether the current operation is a read or a write. Whenever the decoded address is within the range assigned to the peripheral (as indicated by the particular decode logic), a write enable signal is generated to address multiplexor (MUX) 302. The output of address MUX 302 is selected by an OWNER signal. The OWNER signal indicates which of the available processors (i.e., DSP\_0 or DSP\_1)

currently owns the associated peripheral. Only the decoded address from the owner peripheral is allowed to pass to the clocking or latching input of peripheral control register 301.

[0032] The sixteen bit data bus 305 from each of processors 201 is coupled to data MUX 303. Data MUX 303 is also controlled by the OWNER signal to select only one data bus 305 to be passed to the data input of peripheral control register 301. During a write operation, when register 301 receives the write enable signal the data currently supplied from data MUX 302 is latched into register 301. During a read operation a read signal (not shown) is indicated to register 301 by any processor 201 resulting in driving the data bus 305 to the values stored in the peripheral control register 301.

[0033] When dynamic peripheral sharing is enabled, each processor 201 has the ability to read and write to a peripheral control register 301. A write operation to control register 301 is serialized via the two MUXes 302 and 303 that are controlled by the OWNER signal. The OWNER signal is a part of the peripheral-share register set shown in Fig. 5. When dynamic sharing is not enabled, peripheral ownership defaults to a preassigned "master" processor (e.g., DSP\_0) unless the master processor reassigns peripheral ownership at boot time.

[0034] Fig. 4 shows relative timing of events in a write operation to a shared peripheral control register 301 in accordance with the present invention. It will be recalled that data is not transferred into register 301 until the data is present at the  $D_{MUX}$  node and the write enable is asserted from the address MUX 302.

[0035] In Fig. 4, at time t1 the OWNER signal goes high indicating that DSP\_0 owns the peripheral. At time t2, the D0 node having data from DSP\_0 becomes valid at which time a write enable WEO decoded from the address output by DSPO can be asserted. Because the OWNER signal indicates that DSP\_0 is the current assigned owner, MUX 302 couples the WEO signal to the write enable input of register 301 while blocking the WE1 signal. The transition of the WEO signal causes the D0-1 data to be coupled to the  $D_{\text{MUX}}$  output as shown in Fig. 4.

[0036] Hence, the transition at time t3 of the WE1 signal has no effect on this peripheral register 301 even though the WE1 signal is generated by an address asserted by DSP\_1 that is assigned to the peripheral. At time t3 the data lines D1-0 are driven by DSP\_1, but this data is ignored by peripheral control register 301 as indicated by the lack of change in the  $D_{\text{MUX}}$  output.

[0037] At time t4 new data D0-2 is placed on the D0 line and selected by MUX 303 for coupling to the  $D_{MUX}$  line because the OWNER signal remains in a state indicating that DSP\_0 remains the owner. At time t5 WEO is reasserted and coupled to peripheral control register 302 to clock the D0-1 data into register 301. In this manner, conflict between multiple processors 201 attempting to write data in simultaneous or overlapping time periods is prevented.

[0038] Fig. 5 illustrates an exemplary peripheral share implementing the register set 500 useful in invention. A single register set 500 is provided for all peripherals that participate in the peripheral method in accordance with the present invention. Peripheral register set 500 is preferably implemented on the same integrated circuit as processors 201 so that the values stored therein are readily accessible to each processor 201.

six example, there particular [0039] In the peripheral share registers in each set 500 that control ownership and transfer of ownership of peripherals 202. Each of these registers contains a bit dedicated to each peripheral. Multiple bits per processor in each register will be required where more than two processors 201 are permitted to share a peripheral. At boot time, the master processor 201 (e.g., DSP\_0) has write access by default to the OWNER register. All peripherals default to ownership Any processor 201 by the preassigned master processor. can be designated a master processor, however, dynamically configurable not assignment is For ease of understanding particular examples. description all references herein to a master processor will refer to DSP\_0.

The master may assign a peripheral 202 to any of [0040] the other processors 201 by writing to the bits in the OWNER register corresponding to the selected processor. In applications where dynamic processor sharing is not enabled, this assignment is the only register manipulation necessary. Even where dynamic sharing is not enabled, the present invention adds usefulness because the peripheralprocessor assignments can be made by software rather than This enables the chip to be by hard wired connections. end the without knowledge of manufactured processor-peripheral assignments required by that end use.

[0041] The master processor may enable dynamic sharing by setting the dynamic sharing enable bit identified as DSP\_ENABLE in Fig. 5. Once this bit is set, the master

processor no longer has write access to the OWNER register and this register will be writable only by the protocol logic 204 (shown in FIG. 2) which implements the dynamic sharing protocol.

When dynamic sharing is enabled, a processor 201 [0042] must write to its corresponding REQUEST register. example, DSP\_0 writes to the REQUEST\_0 register while DSP\_1 writes to the REQUEST\_1 register. In each REQUEST register one or more bits are associated with each peripheral and the corresponding processor requests access by writing to the bits associated with the desired peripheral. If the desired peripheral is owned by another release the processor must other processor, that peripheral by setting the bits associated with t.he peripheral in its RELEASE register. In the example, DSP\_0 writes to the RELEASE\_0 register while DSP\_1 writes to the Once protocol logic 204 determines RELEASE 1 register. that the appropriate REQUEST and the alternate processor's RELEASE register bits are set, protocol logic 204 will grant ownership of the peripheral 202 to the requesting processor by setting/clearing the OWNER register bits associated with that peripheral. Protocol logic 204 will then clear the REQUEST and RELEASE registers.

[0043] If needed, the master processor may program the PRIORITY register to determine which processor will "win" the resource when simultaneous requests are raised. In the particular examples, the default is to grant the master processor priority. It is desirable that the processor 201 that fails to write to peripheral control register 301 be able to learn of the failure so that appropriate action can be taken (e.g., rescheduling the

write). This is one function of protocol logic 204 shown in FIG. 2.

[0044] Although the invention has been described and illustrated with a certain degree of particularity, it is understood that the present disclosure has been made only by way of example, and that numerous changes in the combination and arrangement of parts can be resorted to by those skilled in the art without departing from the spirit and scope of the invention, as hereinafter claimed.